<template>
  <div>{{ titleInfo.color }} - {{ titleInfo.value }}</div>
  <div>{{ contentInfo?.color }} - {{ contentInfo?.value }}</div>
</template>

<script lang="ts">
import { defineComponent, PropType } from 'vue'
// props 中类型定义
// 第一种方式，直接在本 vue 文件中定义类型
type TitleInfo = {
  value: string
  color: string
}

type ContentInfo = {
  value: string
  color: string
}
// 第二种方式：将所有的 type 放进 types.d.ts 文件中，方便后续统一管理，并且易于后期维护

export default defineComponent ({
  name: 'PropType',
  props: {
    titleInfo: {
      type: Object as PropType<TitleInfo>,
      required: true
    },
    contentInfo: {
      type: Object as PropType<ContentInfo>,
      required: false // 或者不写
    }
  }
})
</script>

<style scoped>
</style>